package co.inventario.modelo.fachada;

import java.sql.SQLException;
import java.util.ArrayList;

import co.inventario.entidad.CiudadDTO;
import co.inventario.modelo.negocio.CiudadNegocio;
import co.inventario.transversal.DAOFactorySQLServer;

public class CiudadFachada {

	public void crear(CiudadDTO ciudadDTO) throws Exception {
		DAOFactorySQLServer daoFactorySQLServer = new DAOFactorySQLServer();
		CiudadNegocio ciudadNegocio = new CiudadNegocio();
		try {
			ciudadNegocio.crear(ciudadDTO, daoFactorySQLServer.obtenerConexion());
			daoFactorySQLServer.confirmarTransaccion();
		} catch (SQLException exception) {
			daoFactorySQLServer.cancelarTransaccion();
			throw new Exception("Se ha presentado un problema intentando crear la ciudad.");
		} catch (Exception exception) {
			daoFactorySQLServer.cancelarTransaccion();
			throw exception;
		} finally {
			daoFactorySQLServer.cerrarConexion();
		}
	}

	public void actualizar(CiudadDTO ciudadDTO) throws Exception {
		DAOFactorySQLServer daoFactorySQLServer = new DAOFactorySQLServer();
		CiudadNegocio ciudadNegocio = new CiudadNegocio();
		try {
			ciudadNegocio.actualizar(ciudadDTO, daoFactorySQLServer.obtenerConexion());
			daoFactorySQLServer.confirmarTransaccion();
		} catch (SQLException sqlException) {
			daoFactorySQLServer.cancelarTransaccion();
			throw new Exception("Se ha presentado un problema intentando actualizar la ciudad.");
		} catch (Exception exception) {
			daoFactorySQLServer.cancelarTransaccion();
			throw exception;
		} finally {
			daoFactorySQLServer.cerrarConexion();
		}
	}

	public ArrayList<CiudadDTO> consultarTodo() throws Exception {
		DAOFactorySQLServer daoFactorySQLServer = new DAOFactorySQLServer();
		CiudadNegocio ciudadNegocio = new CiudadNegocio();
		ArrayList<CiudadDTO> ciudadDTOLista = null;
		try {
			ciudadDTOLista = ciudadNegocio.consultarTodo(daoFactorySQLServer.obtenerConexion());
		} catch (SQLException exception) {
			throw new Exception("Se ha presentado un problema intentando consultar las ciudades.");
		} catch (Exception exception) {
			throw exception;
		} finally {
			daoFactorySQLServer.cerrarConexion();
		}
		return ciudadDTOLista;
	}
}
